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METHOD AND APPARATUS FOR ROUTING PROGRAM DATA IN A 
PROGRAM VIEWING UNIT 



CROSS-REFERENCE TO RELATED APPLICATION 

[0001] This application claims the benefit of the filing date of the Provisional 
U.S. Patent Application entitled "A METHOD AND APPARATUS FOR ROUTING 
PROGRAM DATA IN A PROGRAM VIEWING UNIT", application number 
60/213,291, filed June 22, 2000. 

FIELD OF THE INVENTION 

[0002] The present invention relates to program viewing units such as set top 
boxes used in entertainment systems. More specifically, the present invention 
relates to a method and apparatus for simultaneous viewing of program data 
with content in a clear format and recording of program data with content in a 
scrambled format. 

BACKGROUND OF THE INVENTION 

[0003] Recording devices such as D-VHS video cassette recorders (VCRs) 
and hard disk based recording units are capable of producing high quality 
recordings and high quality copies of recordings without degradation. This 
poses a concern to the motion picture industry who wish to prevent the 
unauthorized copying of copyrighted material. 

[0004] In response, there is a movement by the motion picture industry to 

require service providers, such as terrestrial broadcast, cable, and direct 

broadcast satellite (DBS) companies, to inject copy management protection 
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commands into the system information of program data. The copy protection 
commands provide program viewing units with guidelines as to how program 
data may be recorded at the viewer's location. For example, the copy 
management protection commands may include a "copy never" command to 
indicate that specific program data with content in a clear format should never be 
copied, or a "copy free" command to indicate that specific program data with 
content in a clear format may be copied. The copying of program data with 
content in a scrambled format and later de-scrambling and viewing of the content 
may be permitted with the authorization of the service provider and coordination 
with the program viewing unit. The functionality of program viewing units such 
as set top boxes, thus, has extended beyond merely de-scrambling of content in 
program data from a service provider. 

[0005] A drawback of current program viewing units is that they support either 
the viewing of program data with content in a clear format or the recording of 
program data with content in a scrambled format with the "copy never" copy 
management protection command. Current program viewing units do not allow 
both the viewing of clear content and the recording of scrambled content with the 
"copy never" copy management protection command. 

[0006] Another drawback of current program viewing units is the complexity of 

the copy management protection schemes. For example, Digital Transmission 

Copy Protection (DTCP) used for delivering compressed content over, for 

example, IEEE1394 or USB requires elliptic curve public key cryptography, the 

use of certificates, and the processing of a revocation list. The schemes do not 

take into consideration content that may be playable only to a particular program 

3 



viewing unit, or to program viewing units in a household. A content provider may 
allow copying of content if it could be restricted to the confines of a household. 
SUMMARY 

[0007] A first program viewing unit is disclosed according to an embodiment of 
the present invention. The program viewing unit includes a demodulator unit that 
outputs program data with content in a scrambled format. The program viewing 
unit includes a conditional access unit that de-scrambles the content such that 
the content is in a clear format. A switching unit is coupled to the demodulator 
unit and the conditional access unit. The switching unit simultaneously routes 
the program data with the content in the scrambled format and the program data 
with the content in the clear format in response to instructions from a central 
processing unit. 

[0008] A second program viewing unit is disclosed according to an 
embodiment of the present invention. The program viewing unit includes a 
central processing unit (CPU), a demodulator unit, a conditional access unit, a 
de-multiplexer unit, an encoding unit, and a switching unit. The switching unit is 
coupled to the CPU, the demodulator unit, the conditional access unit, the de- 
multiplexer unit, and the encoding unit. The switching unit is programmable by 
the CPU to route program data between the demodulator unit, the conditional 
access unit, the de-multiplexer unit, and the encoding unit. 
[0009] A method for managing program data according to an embodiment of 
the present invention is disclosed. Program data is transmitted to a switch. The 
switch is selected to transmit the data to one of a de-multiplexing unit, 

conditional access unit, and an encoding unit. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

[001 0] The present invention is illustrated by way of example and not by way 
of limitation in the figures of the accompanying drawings, in which like references 
indicate similar elements and in which: 

[001 1] Figure 1 is a block diagram of an entertainment system according to an 
embodiment of the present invention; 

[0012] Figure 2 is a block diagram of a first program viewing unit according to 
an embodiment of the present invention; 

[0013] Figure 3 is a block diagram of a first conditional access unit according 
to an embodiment of the present invention; 

[0014] Figure 4 is a block diagram of a second conditional access unit 
according to an embodiment of the present invention; 

[0015] Figure 5 is a block diagram of a second program viewing unit according 
to an embodiment of the present invention; 

[0016] Figure 6 is a block diagram of a third program viewing unit according to 
an embodiment of the present invention; 

[0017] Figure 7 is a table illustrating possible routing paths of the switch unit; 
[0018] Figure 8 is a flow chart illustrating a method of managing program data 
according to an embodiment of the present invention; 

[0019] Figure 9 is a flow chart illustrating a method of managing program data 
according to a second embodiment of the present invention; and 
[0020] Figure 1 0 is a block diagram of a third conditional access unit according 
to an embodiment of the present invention. 
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DETAILED DESCRIPTION 

[0021] Figure 1 is a block diagram of an entertainment system 1 00 according 

to an embodiment of the present invention. The entertainment system 100 

includes a program data receiver 110. The program data receiver 110 receives 

program data from one or more service providers. A service provider may be, 

for example, a terrestrial broadcaster, a cable company, a DBS company, an 

Internet service provider (ISP), or other source. The program data receiver 110 

includes a program viewing unit 111. The program viewing unit 1 1 1 operates to 

process the program data into a viewable format and to regulate access of the 

program data to other components on the entertainment system 100. The 

program data may include content, system information, entitlement management 

messages, entitlement control messages, and other data. Content may include 

audio and video data that may be in a scrambled or clear format. System 

information may include information on program names, time of broadcast, 

source, and a method of retrieval and decoding. The system information may 

also include copy management protection commands that provide program 

viewing units with guidelines as to how program data may be recorded. 

Entitlement management messages may be used to deliver privileges to the 

program viewing unit 1 1 1 such as rights and keys. An encrypted key, for 

example, may be a function of the rights granted. Entitlement control messages 

may be used to regulate access to a particular channel. According to an 

embodiment of the present invention, the program viewing unit 1 1 1 supports the 

simultaneous transmission of program data with content in a clear format and 

program data with content in a scrambled format. 
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[0022] The program data receiver 1 1 0 includes a viewing unit 1 12. The 
viewing unit 112 includes a decoding unit (not shown) and a display unit (not 
shown). The viewing unit 112 receives program data from the program viewing 
unit 111. The program data received is in a clear format that allows a program to 
be viewed. According to an embodiment of the present invention, the program 
data receiver 1 1 0 is a digital television set where the program viewing unit 1 1 1 is 
a built in set top box and the viewing unit 1 12 is a Motion Picture Experts Group 
(MPEG) decoder coupled to a display. It should be appreciated that the program 
data receiver 110 may be implemented with only the program viewing unit 1 1 1 
as a stand alone set top box. The program data receiver 1 1 0 is coupled to a 
transmission medium 120. The transmission medium 120 operates to transmit 
data such as program data between the program data receiver 1 1 0 and other 
components in the entertainment system 100. 

[0023] An audio system 130 may be coupled to the transmission medium 120. 
The audio system 130 may include speakers and an audio player/recorder such 
as a compact disk player, mini disk player, or other magneto-optical disk 
reader/writer that may be used to play or record audio data. 
[0024] A D-VHS VCR 1 40 may be coupled to the transmission medium 1 20. 
The D-VHS VCR may be used to record analog or digital audio, video, and data 
transmissions. According to an embodiment of the entertainment system 
network 100, the D-VHS VCR 140 may be used to record program data on the 
transmission medium 120. 

[0025] A hard disk recording unit 150 may be coupled to the transmission 

medium 120. The hard disk recording unit 150 may be a personal computer 
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system, a stand alone hard disk recording unit, or other hard disk recording 
device capable of recording analog or digital, audio, video and data 
transmissions. According to an embodiment of the entertainment system 
network 100, the hard disk recording unit 150 may be used to record program 
data on the transmission medium. 

[0026] A display unit 1 60 may be coupled to the transmission medium 1 20. 
The display unit 160 may be a high definition television that displays digital and 
analog signal transmissions, a conventional television set, or other display unit. 
[0027] A control unit 1 70 may be coupled to the transmission medium 1 20. 
The control unit 170 may be used to coordinate the operation of the components 
on the entertainment system 1 00 and other electronic devices. It should be 
appreciated that Figure 1 is an exemplary entertainment system 100 and that 
other components may be added or used in place of the components described. 
[0028] Figure 2 is a block diagram of a first embodiment of the program 
viewing unit 1 1 1 according to the present invention. The program viewing unit 
1 1 1 includes a central processing unit (CPU ) 210. The CPU 210 supports a 
graphical user interface that may be displayed on either the viewing unit 112 
(shown in Figure 1) or the display unit 160 (shown in Figure 1). The graphical 
user interface allows a user to navigate through various program selections and 
to select a channel that is to be viewed. The CPU 210 determines a frequency 
in which a selected channel is broadcasted on and transmits this information to a 
tuner unit 220. 

[0029] The tuner unit 220 is coupled to the CPU unit 210. The tuner unit 220 

operates to select a frequency in the terrestrial, cable, or satellite broadcast in 
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which to receive program data. The program data received from the selected 
frequency is in the form of signals which are amplified by the tuner unit 220. 
[0030] A demodulator unit 230 is coupled to the tuner unit 230. The 
demodulator unit 230 receives the signals from the tuner unit 220 and converts 
the signals from an analog format to a digital format. The demodulator unit 230 
may, for example, perform quadrature amplitude modulation for cable broadcast, 
quadrature phase shift keying for satellite broadcast, and vestigial side band 
modulation for terrestrial broadcast. The demodulator unit 230 also performs 
error correction on the program data received that may be introduced by the 
channel media. 

[0031] A conditional access unit 240 is coupled to the CPU unit 210 and the 
demodulator unit 230. The conditional access unit 240 receives the program 
data from the demodulator unit 230. If the program data includes content in a 
scrambled format, the CPU unit 210 transmits information regarding a packet 
identifier where entitlement control messages may be found in the program data. 
The entitlement control messages regulate access to a particular channel and 
determines access rights needed to be held by a program viewing unit 1 1 1 in 
order to grant access. The entitlement control messages may also be used to 
deliver a key or deliver information on how to derive a key that may be used to 
de-scramble content in a scrambled format. If the program data includes 
scrambled content, the conditional access unit 240 de-scrambles the content 
using the key. 

[0032] A de-multiplexer unit 250 is coupled to the conditional access unit 240. 

The de-multiplexer unit 250 receives the program data from the conditional 
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access unit 240. The de-multiplexer unit 250 separates the system information 
in the program data from the content in the program data. According to an 
embodiment of the de-multiplexer unit 250, the de-multiplexer parses the 
program data for packet identifiers that are associated with system information, 
audio information, and video information. The de-multiplexer unit 250 transmits 
the system information to the CPU 210 and transmits the audio and video 
information to the viewing unit 112. 

[0033] An encoding unit 260 is coupled to the conditional access unit 240. 

The encoding unit 260 receives the program data from the conditional access 

unit 240. The encoding unit 260 encodes program data with copy management 

protection commands that indicate that the program data is not "copy free." The 

encoding unit 260 interfaces with the components on the transmission medium 

120 (shown in Figure 1) to determine which components are authorized to 

decode the encoded program data. The encoding unit 260 may transmit a key to 

the authorized components for decoding the encoded program data. According 

to an embodiment of the entertainment system 100, the encoding unit 260 may 

initiate an authentication process that identifies devices that are authorized to 

decode encoded program data. According to an embodiment of the present 

invention, the encoding unit 260 encodes program data transmitted on the 

transmission medium 120 using the IEEE 1394 encoding algorithm. It should be 

appreciated, however, that other encoding schemes may be implemented. 

[0034] The CPU 210, tuner unit 220, demodulator unit 230, conditional access 

unit 240, de-multiplexer unit 250, and encoding unit 260 may be implemented 

using any known technique or circuitry. In one embodiment of the present 
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invention, the CPU 210, tuner unit 220, demodulator unit 230, conditional access 
unit 240, de-multiplexer unit 250, and encoding unit 260 all reside on a single 
semiconductor substrate. 

[0035] Figure 3 is a block diagram of a first embodiment of the conditional 
access unit 240 according to the present invention. The conditional access unit 
240 includes a processor unit 330. The processor unit 330 receives the program 
data from the demodulator unit 230 and information regarding a packet identifier 
where entitlement control messages may be found in the program data. For 
program data that includes content in a scrambled format, the processor unit 330 
reads the entitlement control messages and derives a key for de-scrambling the 
content. The processor unit 330 transmits the program data and the key on line 
335. 

[0036] The conditional access unit 240 includes a de-scrambler unit 340. The 
de-scrambler unit 340 is coupled to the processor unit 330 via line 335. The 
processor unit may be a cryptographic processor with a security perimeter which 
prevents the observation or modification of secure processing, e.g. processing of 
access criteria and keys. The de-scrambler unit 340 receives the key and the 
program data off of line 335 and processes the program data. According to an 
embodiment of the present invention, the de-scrambler unit 340 de-scrambles or 
decrypts the content with the key. The content may come from, for example, the 
demodulator unit 230 and is received by the de-scrambler unit 340 on line 325. 
The de-scrambler unit 340 transmits the program data with the content in clear 
format on line 345. 
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[0037] The conditional access unit 240 includes a re-scrambler unit 350. The 
re-scrambler unit 350 is coupled to the de-scrambler unit 350 via line 345. The 
re-scrambler unit 350 receives the program data and processes the data. 
According to an embodiment of the present invention, the re-scrambler unit 350 
re-scrambles the content in the program data with the key transmitted by the de- 
scrambler unit 340 via line 345. According to an alternate embodiment of the 
present invention, the re-scrambler unit 350 re-scrambles the content in the 
program data using a local key. A local key may be a key unique to the program 
viewing unit 1 1 1 or it may be downloaded to the program viewing unit 111. The 
program data with content that is re-scrambled is transmitted onto line 355 by 
the re-scrambler unit 350. The line 355 delivers the program data with content 
that is re-scrambled to the encoding unit 260 (shown in Figure 2). The 
conditional access unit 240 may be implemented as a Application Specific 
Integrated Circuit (ASIC), however discrete implementations may be possible. In 
fact, the processor 330, may be implemented using the main CPU 210. 
[0038] The conditional access unit 240 includes a re-scrambler de-scrambler 
unit denoted RSU de-scrambler unit 360. The RSU de-scrambler unit 360 is 
coupled to the re-scrambler unit 350 via line 355. The RSU de-scrambler unit 
360 receives the program data and processes the data. According to an 
embodiment of the present invention, the RSU de-scrambler unit 360 de- 
scrambles the content in the program data with the key transmitted by the re- 
scrambler unit 350 via line 355. According to an alternate embodiment of the 
present invention, the RSU de-scrambler unit 360 de-scrambles the content in 

the program data using a local key. A local key may be a key unique to the 
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program viewing unit 111. The program data with content that is de-scrambled 
is transmitted onto line 365 by the RSU de-scrambler unit 360. The line 365 
delivers the program data with content that is de-scrambled to the encoding unit 
260 (shown in Figure 2). 

[0039] The program data may also be scrambled using a method where keys 
and control words are used. In this method, the content in the program data may 
be scrambled using control words that may change periodically over time. The 
control words are injected in the program data and scrambled using a key. In 
order to de-scramble the content in the program data, the control access unit 
240 must first derive the key and then use the key to de-scramble the control 
words. The control words are then applied to de-scramble the content. It should 
be appreciated that the re-scrambler unit 350 may process the program data by 
scrambling the content with the original control words and scramble the control 
words with the original key, scramble the program data with local control words 
and keys that are unique to the program viewing unit 111, scramble the content 
with a single local key without using control words, or by using other encoding 
schemes. It should be appreciated that the processor unit 330, the de-scrambler 
unit 340, and the re-scrambler unit 350 may be implemented using any known 
circuitry or technique. 

[0040] The conditional access unit 240 includes a line 346 coupled to line 345 
that transmits program data with content in a clear format to either the de- 
multiplexer unit 250 (shown in Figure 2) or to the encoding unit 260 without 
passing the program data to the re-scrambler unit 350. The line 346 and the line 

355 provides two streams of program data. Line 346 carries a stream having 
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program data with content in a clear format and line 355 carries a stream having 
program data with content that has been re-scrambled. By providing a stream of 
program data with content that is in a clear format and a stream of program data 
with content that has been re-scrambled, the conditional access unit 240 allows 
simultaneous viewing of program data with content in a clear format (de- 
scrambled program data) and recording of program data with content in a 
scrambled format (scrambled program data). 

[0041] It is to be further appreciated that in one embodiment the program data 
with content that is re-scrambled is transmitted onto line 355 by the re-scrambler 
unit 350 which is then received by the encoding unit 260 (shown in Figure 2) and 
that the encoding unit 260 interfaces with the components on the transmission 
medium 120 (shown in Figure 1) to determine which components are authorized 
to decode the encoded program data. The encoding unit 260 may transmit a key 
to the authorized components for decoding the encoded program data. Thus, 
the authorized component may have a decoder. In an alternative embodiment, 
the decoding for the authorized component may be located within the conditional 
access unit 240. Thus, for example, the decoding of content that is re-scrambled 
by the re-scrambler unit 350 may be performed by the de-scrambler unit 340. In 
such an embodiment, keys needed for de-scrambling may be local, or received 
from a remote unit, for example, components authorized to decode the encoded 
program data. 

[0042] Figure 1 0 is a block diagram of a third conditional access unit according 
to an embodiment of the present invention. Figure 10 is similar to Figure 3 

however two additional control mechanisms are present. Received control 

14 



information 1002 via line 1004 controls the de-scrambler unit 340. Additionally, 
re-scrambler unit 350 is controlled via line 1012 from copy generation 
management 1010. For example, received control information 1002 may be 
information concerning a user, viewer, etc. For example, ordering information, 
billing information, payment information, credit information, sponsor information, 
preview information, viewer information, parental control information, etc. may be 
used to control the de-scrambler unit 340. Thus, for example, a parent may set 
a credit amount for a specific viewer and perhaps also a parental viewing setting 
such as general audiences. Likewise the copy generation management 1010 
may control the re-scrambler unit 350 based on information received from, for 
example, the service provider, the content provider, etc. 
[0043] Figure 4 is a block diagram of a second embodiment of the conditional 
access unit 240 according to the present invention. The conditional access unit 
240 includes a processor unit 330 similar to that described in Figure 3. The 
conditional access unit 240 includes a line 335 that is similar to that described in 
Figure 3. The line 335 is used to transmit program data that may include content 
in a scrambled format to the de-scrambling unit 340. The conditional access 240 
unit also includes a de-scrambler unit 340 similar to that described in Figure 3. 
The de-scrambler unit 340 outputs program data with content in a clear format to 
either the de-multiplexer unit 250 (shown in Figure 2) or to the encoding unit 260 
(shown in Figure 2) via line 345. The conditional access unit 240 further 
includes a line 436 coupled to the line 335. The line 436 transmits program data 
that may include content in a scrambled format to the encoding unit 260, by- 
passing the de-scrambling unit 340. 
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[0044] The line 436 and the line 345 provide two streams of program data. 
Line 345 carries a stream having program data with content in a clear format and 
line 436 carries a stream having program data with content that is scrambled. 
By providing a stream of program data with content that is in a clear format and a 
stream of program data with content that has been scrambled, the conditional 
access unit 240 allows simultaneous viewing of de-scrambled program data and 
recording of scrambled program data. 

[0045] Figure 5 is a block diagram of a second embodiment of the program 

viewing unit 1 1 1 according to the present invention. The program viewing unit 

1 1 1 includes a CPU 210, a tuner 220, a demodulating unit 230, a first conditional 

access unit 240, a de-multiplexing unit 250, and an encoding unit 260. The CPU 

210, tuner 220, demodulating unit 230, conditional access unit 240, first 

conditional access unit 240, demultiplexing unit 250, and encoding unit 260 

operate similarly as described in Figure 2. The program viewing unit 1 1 1 further 

includes a second conditional access unit 540. The second conditional access 

unit 540 may be built into the program viewing unit 111. Alternatively, the 

second conditional access unit 540 may be an add-on feature to the program 

viewing unit 111. For example, the program viewing unit 1 1 1 may have a 

Personal Computer Memory Card International Association (PCMCIA) slot that 

receives a PCMCIA card with a second conditional access unit 540. 

[0046] The second conditional access unit 540 is coupled to the CPU 21 0, the 

first conditional access unit 240, and the encoding unit 260. The second 

conditional access unit 540 receives program data with content in a clear format 

from the first conditional access unit 540 and processes the data in response to 
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instructions from the CPU 210. According to an embodiment of the present 
invention, the second conditional access unit 540 re-scrambles the content in the 
program data with a key transmitted by the first conditional access unit 240. 
According to an alternate embodiment of the present invention, the second 
conditional access unit 540 re-scrambles the content in the program data using a 
local key. If the content was originally scrambled using control words and keys, 
the second conditional access unit 540 may process the program data by 
scrambling the content with the original control words and scramble the control 
words with the local key that is unique to the program viewing unit 111, scramble 
the content with a single local key without using control words, or use other 
encoding schemes. The second conditional access unit 540 transmits the re- 
scrambled program data to the encoding unit 260. In some implementations, the 
encoding unit 260 may not be required if the content is scrambled. The use of a 
local or downloaded re-scrambling key may eliminate the requirement for 
complex encoding schemes such as Digital Transmission Copy Protection 
(DTCP). In this embodiment of the program viewing unit 111, the first conditional 
access unit 240 need not include a re-scrambling unit 350 (shown in Figure 3) 
nor an additional line 436 (shown in Figure 4) for routing program data with 
content in a scrambled format. 

[0047] The second conditional access unit 540 allows a stream of program 

data with content that has been re-scrambled to be routed to the encoding unit 

250 while program data with content that is in a clear format is transmitted to 

either the encoding unit 250 or to the de-multiplexer unit 250. By facilitating the 

transport of a stream of program data with content that is in a clear format and a 
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stream of program data with content that has been re-scrambled, the program 
viewing unit 1 1 1 allows simultaneous viewing of de-scrambled program data and 
recording of scrambled program data. 

[0048] Figure 6 is a block diagram of a third embodiment of the program 
viewing unit 1 11 according to the present invention. The program viewing unit 
1 1 1 includes a CPU 210, a tuner 220, a demodulating unit 230, a conditional 
access unit 240, a de-multiplexing unit 250, and an encoding unit 260. The CPU 
210, tuner 220, demodulating unit 230, conditional access unit 240, 
demultiplexing unit 250, and encoding unit 260 operate similarly as described in 
Figure 2. The program viewing unit 1 1 1 further includes a switching unit 610. 
The switching unit 610 is coupled to the CPU 210, the demodulating unit 230, 
the conditional access unit 240, the de-multiplexing unit 250, and the encoding 
unit 260. The switching unit 610 operates as a router that may direct program 
data to the conditional access unit 240, the de-multiplexer, or the encoding unit 
260 with the direction of the CPU 21 0. For example, the switching unit 61 0 may 
direct program data with content in a scrambled format received from the 
demodulator unit 230 to the encoding unit 260 while simultaneously directing 
program data with content in a clear format received from the conditional access 
unit 240 to the encoding unit 260 or to the de-multiplexer unit 250. In this 
embodiment of the program viewing unit 1 1 1 , the conditional access unit 240 
need only perform the functionality of de-scrambling program data with content 
in a scrambled format. The conditional access unit 240 need not include a re- 
scrambling unit 350 (shown in Figure 3) nor an additional line 436 (shown in 

Figure 4) for routing program data with content in a scrambled format. 
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[0049] The switching unit 61 0 allows a stream of program data with content 
that is scrambled to be routed to the encoding unit 250 while program data with 
content that is in a clear format is transmitted to either the encoding unit 250 or 
to the de-multiplexer unit 250. By facilitating the transport of a stream of 
program data with content that is in a clear format and a stream of program data 
with content that has been scrambled, the program viewing unit 1 1 1 allows 
simultaneous viewing of de-scrambled program data and recording of scrambled 
program data. According to an embodiment of the present invention, the switch 
unit 610 may be implemented with a multiplexer. 

[0050] The switching unit 61 0 may also be directed by the CPU 21 0 to perform 
other routing operations as shown on the table illustrated in Figure 7. The 
switching unit 610 may provide a connection that routes program data from the 
demodulator unit 230 to the conditional access unit 240 to facilitate real-time de- 
scrambling of program data with content in a scrambled format. In this mode, 
the switching unit 61 0 may also provide a connection from the output of the 
conditional access unit 240 to the de-multiplexer 250 to facilitate the display of 
the program data locally on the viewing unit 112 (shown in Figure 1). The 
switching unit 610 may also provide a connection from the output of the 
conditional access unit 240 to the encoding unit 260 to facilitate the display of 
de-scrambled program data on the display unit 160 (shown in Figure 1) and/or 
the recording of the de-scrambled program data on either the D-VHS VCR 140 
(shown in Figure 1) or the hard disk recording unit 150 (shown in Figure 1). 
[0051] The switching unit 610 may provide a connection that routes program 

data from the demodulator unit 230 to the encoding unit 260 to facilitate 
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displaying of unscrambled program data on the display unit 160, or the recording 
of scrambled or unscrambled program data by either the D-VHS VCR 140 or the 
hard disk recording unit 150. In this mode, the switching unit 610 may provide a 
connection from the demodulator unit 230 to the de-multiplexer unit 250 to 
facilitate the display of program data on a local display in the viewing unit 112. 
[0052] The switching unit 61 0 may provide a connection that routes program 
data from the demodulator unit 230 to the de-multiplexer unit 250 to facilitate the 
display of unscrambled program on a display in the viewing unit 112. In this 
mode, the switching unit 610 may also provide a connection from the 
demodulator unit 230 to the encoding unit 260 to facilitate the display of program 
data on the display unit 160. 

[0053] The switching unit 61 0 may provide a connection that routes program 
data from the encoding unit 260 to the de-multiplexer unit 250 to facilitate the 
display of stored unscrambled program data. 

[0054] The switching unit 61 0 may provide a connection that routes program 

data from the encoding unit 260 to the input of the conditional access unit 240 to 

facilitate the de-scrambling of stored program data with content in a scrambled 

format. In this mode, the switching unit 610 may also provide a connection from 

the output of the conditional access unit 240 to the de-multiplexer unit 250 to 

allow the display of the program data on the display unit 160. 

[0055] The switching unit 610 may provide a connection that routes program 

data from the conditional access unit 240 to the de-multiplexer unit to facilitate 

the display of de-scrambled program data onto a local display on the viewing unit 

112. In this mode, the switching unit 610 may also provide a connection from 
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the output of the conditional access unit 240 to the encoding unit 260 to allow the 
display of the program data on the display unit 160. 

[0056] The switching unit 61 0 may provide a connection that routes program 
data from the output of the conditional access unit 240 to the encoding unit 260 
to facilitate the display of de-scrambled program data on the display unit 160 or 
to store de-scrambled program data on the D-VHS VCR 140 or the hard disk 
recording unit 150. In this mode, the switching unit 610 may also provide a 
connection from the output of the conditional access unit 240 to the de- 
multiplexer 250 to facilitate the display of the program data on the display of the 
viewing unit 1 12. 

[0057] Figure 8 is a flow chart illustrating a method of managing program data 
according to an embodiment of the present invention. At step 801 , content in the 
program data is de-scrambled such that the content is in a clear format. 
According to an embodiment of the present invention, de-scrambling the content 
in the program data includes deriving a key from entitlement control messages in 
the program data, decoding a control word with the key, and decoding the 
content with the control word. 

[0058] At step 802, the program data with the content in the clear format is 
output onto a first line. 

[0059] At step 803, the program data with the content in the clear format is 

processed such that the content in the clear format is in a scrambled format. 

The content in the clear format may be processed by scrambling the content in 

the clear format with an original key or scrambling the content in the clear format 

with an original control word and further scrambling the control word with an 
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original key. Alternatively, processing the program data with the content in the 
clear format may include scrambling the content in the clear format with a local 
key. 

[0060] At step 804, the program data with the content in the scrambled format 
is output onto a second line. 

[0061] Figure 9 is a flow chart illustrating a method of managing program data 
according to a second embodiment of the present invention. At step 901 , the 
program data is transmitted to a switching unit. The program data may include 
content that is in a clear format or content that is in a scrambled format. The 
program data may be transmitted to the switching unit from a demodulator unit, a 
conditional access unit, or an encoding unit. 

[0062] At step 902, the switching unit is selected to transmit the data to one of 
a de-multiplexing unit, conditional access unit, and an encoding unit. The 
switching unit may be selected by a CPU. The switching unit may be selected to 
transmit the program data from the demodulator unit to the conditional access 
unit in order to facilitate real-time de-scrambling of program data. The switching 
unit may be selected to transmit the program data from the demodulator to the 
encoding unit in order to facilitate displaying of unscrambled program data on a 
display unit on the network, or storing of scrambled or unscrambled program 
data on a recording device on the network. The switching unit may be selected 
to transmit the program data from the demodulator unit to the de-multiplexer unit 
in order to facilitate the display of unscrambled program data. The switching unit 
maybe selected to transmit the program data from the encoding unit to the de- 
multiplexer in order to facilitate the display of stored unscrambled program data. 
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The switching unit may be selected to transmit program data from the encoding 
unit to the input of the conditional access unit in order to facilitate the de- 
scrambling of stored scrambled program data. The switching unit may be 
selected to transmit program data from the output of the conditional access unit 
to the de-multiplexer unit in order to facilitate the display of de-scrambled 
program data on a local display. The switching unit may be selected to transmit 
program data from the output of the conditional access unit to the encoding unit 
in order to facilitate the displaying of de-scrambled program data on a display 
unit on the network or the recording of de-scrambled program data on a 
recording device on the network. 

[0063] In the foregoing description, the invention is described with reference to 
specific exemplary embodiments thereof. It will, however, be evident that 
various modifications and changes may be made thereto without departing from 
the broader spirit and scope of the present invention as set forth in the appended 
claims. The specification and drawings are accordingly to be regarded in an 
illustrative rather than in a restrictive sense. 
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